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ABSTRACT 


This thesis introduces an economical way of implementing the test 
pattern generation for built-in test. A layout generator as well as a netlist 
generator are written and validated. In addition, we use the netlist generator 


to investigate the properties of nonprimitive polynomials. 
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I. INTRODUCTION 


When a logic chip or board has been fabricated, testing is performed on 
the finished product to ensure that it is free of manufacturing defects. The 
device is mounted in the test socket of a tester which drives its input 
terminals with logic signals called test vectors. The responses to these input 
stimuli are then obtained at the output terminals of the device. The test 
patterns are generated either by a software algorithm or by hardware built into 
the test equipment or by hardware actually embedded in the device to be 
tested. Good responses are obtained by simulation or by measurement of the 
output of a number of "good” devices. Responses to the test patterns may be 
compressed into a unique binary number which accumulates all the response 
data. The simplest compressed measure is the parity bit used in digital 
communication. Responses then are compared with "good” outputs to verify 
correct operation of the device under test. 

At low levels of integration, it is possible for an engineer to manually 
write the test patterns from the functional specification for the device. 
However, this can be a difficult and time consuming process for devices 
containing just a few hundred circuits, and manual test pattern generation 
for Very Large Scale Integrated (VLSI) devices may require many engineer- 
years of effort. The purpose of this thesis is to investigate the on-chip test 
pattern generation so that we can avoid the time and storage required when 
we do it off-chip. An economical way of implementing the test pattern is 


introduced. A layout generator as well as a netlist generator are written and 


validated. In addition, we use netlist generator to investigate the properties 
of nonprimitive polynomials. 

The organization of this thesis is described as follows. In Chapter Two, 
we discuss Built-in Self Test (BIST). Chapter Three discusses Cyclic 
Redundancy Code (CRC) dividers and Linear Feedback Shift Registers (LFSR) 
and explains how these devices can be used as pseudorandom pattern 
generator. In Chapter Four, the weighted pseudorandom pattern generator 
(WPRPG) is discussed and a set of experiments are performed to investigate 
the behavior of WPRPG. Chapter Five summarizes the results and presents 
the conclusions of the thesis. "C" program listings for the thesis project are 


listed in Appendix A. 


II. BUILT-IN SELF TEST 


A. DESIGN FOR TESTABILITY 

Design for testability (DFT) is motivated by the need to reduce the costs of 
testing. The main testability considerations are difficulty of test generation, 
test sequence length, test application cost, fault coverage and fault resolution. 
The costs are basically those of the computer time required to generate test 
patterns, personnel to write the test pattern program and test equipment 
[Ref.1]. The objective of DFT is to design circuits from the outset in order to 
limit in magnitude the test generation efforts and test verification [Ref.2]. 

Three basic approaches for designing are ad-hoc testing, structured design 
approach, and built-in self testing. Here we focus only on built-in self test 
approach using built-in logic block observation (BILBO) technique. This 
technique, uses the scan path and level sensitive scan design (LSSD) concept 
combines it with the signature analysis concept [Ref.3]. The complete test 
generation and observation arrangement can be implemented as shown in 
Fig. 2.1 [Ref.2]. The pattern generator on the left is used as the sequence 
generator to generate test patterns, which will be applied to the combinational 
circuitry under test. The register on the right is used as response analyzer. 
After a certain number of pattens applied, the responses collected by the 
analyzer will be used to determine if the circuit is correct. In LSSD or other 
structural design techniques, a considerable amount of test data volume is 
involved with the shifting in and out. Testing a circuit requires the 


application of the test patterns and the comparison of the actual circuit 
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Figure 2.1 The Complete Test Generation 


response with the correct response. General-purpose testers, though 
commonly used for this purpose, are very expensive. Tester cost is not the 
only difficulty encountered in using an external tester. There are also 
problems: 


eTime - The turnaround time to generated test patterns, the time taken to 
apply the test patterns, and the computation time are growing too large. 


e Volume - The number of test patterns is becoming too large to be handled 
efficiently by the tester hardware. 


B. BUILT-IN TEST 
Several techniques have been proposed for reducing the complexity of 


external testing by moving some of the tester functions onto the chip itself or 


onto the board on which the chip are mounted. One approach to eliminate 
testing problem above is to incorporated built-in self test circuitry into the 
circuit under test (CUT). In this technique, test patterns and output responses 
are generating in BIST designs. The test patterns are fed as input to the circuit 
under test, and output responses from the circuit under test are then 
compressed through signature analyzer to form a signature. In the next 
section we will discuss test pattern generation in detail. 

To solve the problem of analyzing and storing the large amount of data, 
which is required for a good response generation, we may use a compact 
testing method. This technique, signature analysis, reduces the memory and 
additional circuit units [Ref.4]. This technique can be used when it is not 
feasible to compare test result data with reference data, for each input test 
pattern. If the reference data available at the same rate and in synchronism 
with the data being tested there is no advantage using this technique. 

By analyzing the signature, we can determine whether the circuit under 
test is faulty or not. Since compact testing compresses response data and 
compares the signature only once, the difficulty of analysis and storage of 
huge amounts of test response data can be avoided. Furthermore, BIST has 
another important advantage that the circuit under test is fed with random 
test patterns at the functional clock rate. Hence, it is possible to perform high 
speed testing using internal test device built in the circuit under test. For a 


detailed discussion on signature analysis one can consult Barus' thesis [Ref.5]. 


C TEST GENERATION 

In designing a circuit one always wants to have a way to verify the design 
before and after the chip is fabricated. Before the fabrication one can have 
design verification by circuit simulation either at functional, switch, or device 
level. After the chip is fabricated, a designer has to find a way of testing the 
circuit by providing various test patterns (controllability) to the circuit and 
measure the output (observability). In practice, a designer assumes that the 
faults in a circuit can be either stuck-at-0 or stuck-at-1. A node stuck-at-0 
means the node is shorted to the ground, while a node stuck-at-1 means the 
node is shorted to Vdd or power supply. Although there are other fault 
models the stuck-at fault is the most commonly used one. Moreover, to 
simplify the problem, the 'single' fault model is used: a circuit is faulty only 
at a single node. This simplification may seem unreasonable but practically it 
is useful and is used in today's theoretical research and industrial circuits 
[Ref.6]. A network of n nodes has 2n possible single faults since for each node 
there are two possible faults: either stuck-at-0 or stuck-at-1. To exhaustively 
test the circuit we may have to generate all possible test patterns and apply 
them to the primary inputs of the circuit. The circuit complexity may be 
characterize by the number of primary inputs. The number of internal nodes 
is generally more than square of the number of inputs. 

Consider a 2-input 'and' gate with nodes A, B as primary inputs and node 
C as the primary output. Possible exhaustive test patterns are AB = ( 00, 01, 10, 
11 }. For node B with stuck-at-0 fault to be detected, the test pattern must be 


11. Other faults and their corresponding detecting vectors are shown in Table 


2.1. To have a 100% fault coverage, we need to apply all four possible test 
patterns for the AND gate. For a circuit of k inputs, the number of exhaustive 
input patterns would be 2K, Generation test patterns off-line requires 
tremendous storage and extremely long data transmission time. To save both 
space and time the random" test patterns should be supplied on chip hence 
the built-in test pattern generation. The randomness is not a necessary 
condition for the built-in test; all we need is to provide a set of test patterns 
that can capture all faults. The naive approach would be an k-bit counter that 
can generate (or count) patterns from 0 up to 2* _ 1. However, the counter 
approach is more expensive than the linear feedback shift register (LFSR) to 
be explained in the next chapter because sufficient coverage may be achived by 


test patterns generated from an LFSR. 


TABLE 2.1 THE FAULTS AND THEIR CORRESPONDING 
DETECTING VECTOR 


Fault-type | Detecting vector 





Test generation is used to search a sequence of input test vectors which 
verify the correctness of the circuit and test verification is concerned to find 
measures of effectiveness of a given set of test vectors. All of these 
consideration should be considered when designing a test strategy and test 
plan. Moreover, it is sometimes important to locate the fault as well as 
detecting it. The strategy of testing can be changed depends on whether it is 
desired to detect the fault only, or to detect and to locate the fault. The 
manual generation of test patterns is a difficult, time consuming job even for 
moderate circuits. Using of pseudo-random pattern generator (discussed in 
Chapter III) and generation of a test vector which detects a single failure 
indicates the degree of underestimation of the importance of the test 
generation process. Faults simulation has been the goal of the test generation, 
yielding a quantitative measure of test effectiveness. In other words, a test 
sequence is considered good if it can detect a high percentage of the possible 
faults in the circuit under test. 

Sometimes the designer has the knowledge about the circuit behavior 
and does not need all exhaustive test patterns for capturing faults. In these 
cases, the test patterns are not uniformly distributed. The best approach to 
save unnecessary pattern generation time is to provide test patterns that 
reflect the circuit behavior. Exhaustive pattern generation may be technically 
feasible and can cover all faults but it is not economical feasible for circuits 
with large number of primary inputs. A circuit with 64 inputs is common in 
today's digital design and exhaustive testing patterns of 264 = 1.84467 x 10"? or 
about 10%. With a testing device of 20 MEZ, test pattern generation frequency 


(or 50 ns per pattern) we need 107° x 50ns = 10! sec. or 10* centuries. For 


example, if we know a certain bit would be '1' 75% of the test patterns we then 
can 'bias' our test patterns to force '1' at that node 75% of the time. 

To increase the efficiency of random test pattern generation, Parker [Ref. 
7] proposed a method by adaptively controlling the source statistics. Adding 
an adaptive mechanism to random test pattern generation adds a trivial 
amount of additional computation to the process. Based on method 
mentioned above, in [Ref. 8] the new test generation method named 
Weighted Test Pattern Generation (discussed in Chapter IV) has been 
proposed to reduce the number of test pattens required for high fault 
coverage. Using this method, the adaptive mechanism is provided by 
monitoring the logic-level transition activity. In [Ref. 9] the adaptive 
weighted test pattern generation is applied to develop a minimal set of test 
patterns with maximum fault coverage. The result shows that adaptive test 
generation of a set of probabilistic stimuli detect a significantly large 
percentage of the fault in the selected circuits. The above technique indicates 
that a method for generating weighted test patterns is a powerful way to 
reduce the number of test patterns. The generation of weighted test patterns 


can be achieved by weighted LFSR which is discussed in Chapter IV. 


HI. CRCAND PRPG GENERATORS 


A. OVERVIEW OF CYCLIC REDUNDANCY CODE (CRC) 

CRC is commonly used in today's digital communication systems for 
error detection. For example, CRC-4 is used in European ISDN primary rate 
access and CRC-12 is used in U-interface superframe of the ISDN basic rate 
access [Ref. 10]. A CRC-d code is an n-d linear code that consists of n-bits of 
information and d bits of checkword. A CRC can be implemented in 
hardware by an LFSR and is called a CRC divider, to be explained in the next 
section. A message of n-bit is divided by a CRC-d divider and the d-bit 
remainder becomes a checkword that appends to the message bits. A 
transmitter sends this n + d bit block to the receiver. A receiver applies the 
received n-bit message to its CRC divider and the remainder or checkword is 
then compared with the received checkword. If the checkword generated at 
receiver end is the same as the checkword received, the transmission is 
treated as error free; otherwise transmission error is detected. Each CRC-d 
code is defined by a characteristic polynomial p(x) and each p(x) corresponds 
to a hardware implementation called CRC divider. 

An example is instructive to understand the CRC process. Let the 10-bit 
message be 1101011011 and the CRC divider polynomial g(x) = x 4x41. The 
message can be expressed as m(x) = x + x + xf + x + Š + x + 1. Since m(x) = 
(x? +x? + x)mod g(x) = r(x)mod g(x), the remainder in the CRC-4 divider is 
1110, and the transmitter sends out the concatenation of m(x) and r(x) or 


11010110111110 to the receiver. When the receiver receives the message, the 


10 


first ten message bits will be applied to its CRC-4 divider which produces its 
own remainder. If the transmission is error free then there would be no error 
in the message bits and the remainder generated by the receiver should be the 
same as that it has received i,e., 1110. Suppose, we have a unreliable 
transmission and the message bits received by the receiver is 1001011011 or 
m'(x) = x? + x + x + x + x + 1. Now the remainder generated by the receiver 


would be 00001 and is different from 1110 so that the transmission error is 


detected. 


B. CRCDIVIDER 

The general configuration of a CRC divider is a set of delay flip-flops and 
XOR gates connected in such a way that the last stage output feeds to a set of 
intermediate stages. Fig. 3.1 shows an example of CRC-9 divider. Note that a 
CRC-d divider requires d flip-flops and k XOR gates for the p(x) with k terms. 
It has been shown in [Ref. 11] that when the generator polynomial is 
primitive the number of distinct patterns a CRC divider can produce would 
be 2* for a p(x) with k terms, assuming the initial value in the divider is zero. 
Table 3.1 shows example of various patterns generated by non-primitive p1(x) 


= x + x + x7 + x7 + x +1 and primitive p2(x) = x? 


N polynomials. Notice 
that p1(x) and p2(x) are initialized to the same value of 10011. The primitive 
p2(x) cycles through all possible 1 patterns except 0. The 
nonprimitive polynomial p1(x), can only cycle through 6 distinct patterns. In 


other words, if we were to use p1(x) for pattern generation we would miss 31 - 


6 = 25 patterns hence reduce the fault coverage. 
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F. 
| : delay/shift register = 


CQ  : exclusive-OR gate 


Figure 3.1 Method for Obtaining CRC-9 Checkwords Using a Shift Register 
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TABLE 3.1 VARIOUS PATTERNS GENERATED BY 
NONPRIMITIVE AND PRIMITIVE 


Number of Test Pattern | Primitive Test Pattern | Nonprimitive Test Pattern 
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When using p1(x), we need seven distinct initial values to cover all 
possible patterns (See Table 3.2). Let cover set S; denote the set of patterns 
that can be generated with initial value i. Let ||5,|| be the norm of Sj, or the 
number of elements in S; or periodicity. Notice that S21 = (21) is the only case 
that the periodicity is 1. When a state cover set has only one number, 
(periodicity 1), We call that an inertial state. Several properties of the cover 
sets are the following: 

1. Ifae S; then Sg =S; Note that since the LFSR is a deterministic 
device and the next state q' of current state q is uniquely determined, 
therefore if q € S;then q' € S;, when i #0. 

2.]If i*j then either S; Sj =Ø or S; = Sj. [proof:] qj such that qie Si, 
qie Sj forizj then Vqe Sj,qe Sj. Because the state transition is 
deterministic so the transitions in both S; and S; are in unison: n cycles after 
qi should be in both sets or q; (n) = q E S; and q; (nm) =q€ Sj. 

3. [Si] < 2" —1 since the maximum number of states of n stages is 2" - 1. 
Therefore, 


n-1 
lat e ah 
11 


TABLE 3.2 THE COVER SETS GENERATED BY DIFFERENT 
INITIAL VALUE 


Initial Value Periodic Sequence Generated 
00001 (1) | 00001 00010 00100 01000 10000 11111 (1, 2, 4, 8, 16, 31) 


306 COM 039 
DD 20823 0720899 


7, 1, 28 
9, 18, 27 
19, 25, 13, 26, 11, 22 
21 
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C. PSEUDORANDOM PATTERN GENERATOR 

The most popular hardware pseudorandom pattern generator is the 
Linear Feedback Shift Register (LFSR). An LFSR composed of master-slave 
flip-flops and XOR gates. An LFSR implements a pseudorandom generator by 
feeding back a set of intermediate stages to the input. The general 
configuration is to add (modulo-2) all feedbacks to the input. The number of 
feedback terms are dictated by the number of terms in the characteristic 
polynomial p(x). For example, if p(x) = x? + x + x + x + 1, its LFSR can be 
implemented as Fig. 3.2. 

Note that there is only one multiple input XOR gate in Fig. 3.2. A CMOS 
XOR gate with multiple inputs is more economical only in schematic not in 
implementation. Due to the regularity requirement in the VLSI, a designer 
will not use this scheme. If we were to layout an XOR gate of more than 3 
inputs the layout would be much larger than the neighboring flip-flop. If we 
were to replace a multiple inputs XOR gate with multiple 2-input XOR gates, 
this feedback circuit for modulo-2 addition would again become larger than 
the neighboring flip-flop. Fig. 3.3 demonstrates such an arrangement; the 
routing wires to the XOR gates was dictated by the inherent nature of the tree 
structure similar to that of a parity tree. An n-input XOR gate can be 
implemented by (n - 1) 2-input XOR gates. For example, 4-input XOR can be 
expressed as: XOR(a, b, c, d) = XOR(XOR(a, b), XOR(c, d)). The alternative 
LFSR could be implemented as in Fig. 3.4. The beauty of this scheme is that 
although we use the same number of multiple 2- input XOR gates as that of 
Fig. 3.3 the area requirement is more economical: each XOR gates can be of 


the same size as that of a flip-flop. The biggest savings are the routing area 
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and the regularity of Fig. 3.4. The realization of Fig. 3.4 has less interstage 
delay than that of Fig. 3.3. Consequently, Fig. 3.4 could operate at a higher 
clock rate than Fig. 3.3. 

With two basic leaf cells of a master-slave flip-flop and a 2-input XOR gate 
we can easily compose an LFSR to implement a given characteristic 
polynomial. Section 3.5 will discuss a generator that generates the LFSR 


layout for users. 














5 x + × +1 


Figure 3.3 Different LFSR Implementing, x + x 
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It is interesting to note the difference between Fig. 3.5 and Fig. 3.4 for a 
given characteristic polynomial: a CRC divider has one more XOR gate than 
an LFSR. From this observation, we can use a CRC divider to implement 
pseudorandom generator and the input XOR gate is used only for 
initialization. When the input stream of CRC divider is zero the input XOR 
gate is equivalent to a short circuit and therefore a CRC divider reduces to a 
LFSR pseudorandom pattern generator. On the other hand, for practical 
purposes, we need to provide a mechanism for initializing an LFSR so an 
input is required and we will implement an LFSR like a CRC divider. 
Therefore, in this thesis we treat the implementation of a CRC divider as a 


substitute for an LFSR pseudorandom generator. 


7 å Ho 





» output 


5 3 


Figure 3.4 Alternate LFSR Implementation of ext text 
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Figure 3.5 CRC Implementing x + x + x3 + x +1 


D. NETLIST GENERATOR FOR CRC DIVIDERS 

This section describes a netlist generator for CRC dividers. A "C" 
program named crcnet.c was written as part of the thesis research (see 
Appendix A). This program is used to parse the user input and produce the 
corresponding netlist px.net and its switch-level stimulation file px.l where 
px is the file name given by the user. Using the simulation file we can 
simulate the behavior of the CRC divider. A typical usage of the crcnet.c is 
shown in Appendix B for the generation of a CRC divider like the one in Fig. 
3.5 by executing a unix command: 

Jo crenet 111011 10101 x54310 


> +x+1, 


where 111011 is the representative of the polynomial XO E 
10101 is the initial value and x54310 is the filename of the two output files 


produced, x54310.net and x54310.1. 
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The network description file produced by crcnet is converted to an 
intermediate file, px.sim by using the NETLIST command. Another 
conversion occurs when producing a binary file suitable for use in RNL and is 
done by the PRESIM commands. The command file px.l should load one or 
more libraries of standard functions and should read in the binary description 
of the circuit created by PRESIM. The command file should also contain LISP 
commands and definitions required for the circuit functional simulation [Ref. 
12). This netlist simulator can provide the user a validation of certain 
polynomial's behavior. Besides, it can be used to check against the 


simulation based on the circuit extraction from the layout. 


E. CRCLAYOUT GENERATOR 

A netlist is used to describe a circuit and the simulation on a netlist is to 
verify the functional correctness of the circuit. To realize a circuit on a silicon 
chip we need to have the layout of the circuit. A CRC layout generator was 
written as a part of this research that can generate CMOS mask specifications 
for a given CRC divider polynomial. 

This program, called crcmag.c, is used to get user's input and generate the 
corresponding layout file px.mag. The input is similar to that required by 
crcnet. Fig. 3.6 shows the CRC divider for X+x+1 generated by crcmag.c. 

The area is 51,660 square units (630 x 82). The actual area of a layout 
depends not only on the order of the polynomial, but also on the number of 
terms. To calculate the area , the following formula can be used: NeL] + 
MeL2 assuming both MSFF and XOR are of the same height. In the formula 
the N is the order of the polynomial, the M is the number of terms present , 


L is the width of the MSFF (141), Lo is the width of the XOR (100). Once the 
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layout is generated, extractor is used to convert the graphical layout into a 
circuit extraction px.ext file which contain information about the layout 
environment, geometry, and connectivity. This .ext file is converted to an 
intermediate file (the .sim file) by using the unix command EXT2SIM. 
Similar to the netlist generator approach, the unix command PRESIM is used 
to convert a .sim file to a binary file to be used in RNL. Table 3.3 shows an 
example of exhaustive test patterns generated by both crcnet and crcmag 
implementing x? + x + 1. Notice that both the netlist and the layout-extracted 
circuit produce identical patterns. In other words, the crcmag.c can produce a 


layout that realize the circuit behavior described on simulated earlier by 


crcnet.c. 
Vdd! cYdd! x vadi nn Y ad 3 
® we NM E پل وب " ا‎ S 7 e 
= : $ CHE am Am ا‎ e 00 Eu oea 7 
amet GET سیا‎ FOE کو‎ AA نا یی تچ سرن کے یی کک‎ 
"a ae b èa Ëi یڈ‎ HELLE DT iB in| Bie Bb, is KN: Be "bit... 
.. ` ` 
input på Vx 2 š > ke Pet i SN A > 4 uu Wo ta PREIS TE God i T i ) 
pD ^k à “e RE: Jo FRØ کر‎ E & Bi: Ë à t IX, HE £ 
NG . + PR SAN ` E . ` 1 ` 
. € y t eY $e | Y ° ade o aa, O Poe ee : 
e Qro oM Reese uu Sog: NAN es : ARREST ANS ES ur NS. Mer mme ette uve te 
GND 1 GND | ` ` GND ۱ NASAN NOW 5۵۹۰۱۹۹۰ 448۹ ` CND ١ یہ‎ “sa ANNAN ANNA ... y ` GND? ` `` ss 


Figure 3.6 CRC Generate by MAGIC 
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TABLE 3.3 TEST PATTERN GENERATED BY NETLIST AND 
LAYOUT 


Test Pattern generated by crenet | Test Pattern generated by crcmag 


نم بج یی حلر ان 13 GO‏ 
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IV. WEIGHTED PRPG 


Å useful extension of pseudo-random testing is weighted pseudo-random 
testing. In this approach the LFSRs are modified so they can supply unequal 
distribution of '1's and '0's per input bit of test patterns. The concept of 
weighted pseudorandom patterns (WPRP) was introduced in the early 1970's 
by [Ref. 7]. In this chapter we describe two methods of designing WPRP 
generators: netlist and circuit layout. Besides, we compute the output signal 


probabilities. 


A. OVERVIEW OF WPRPG 

To reduce the number of test patterns required for high fault coverage the 
technique named Weighted Pseudorandom Pattern Generator (WPRPG) has 
been used in built-in self test. WPRPG testing is a way to provide control to a 
random test set to achieve a maximum fault coverage in relatively small 
number of patterns [Ref. 13]. This control is achieved by adjusting the 
probability of the random values being applied at each input of the CUT. [Ref. 
14] has indicated that the weighted random patterns can be generated internal 
to the device by additional circuitry at the output of an LFSR. In this method, 
the adaptive mechanism is provided by monitoring the logic level transition 
activity of the CUT [Ref. 13]. A weight is then assigned to a primary input of 
the CUT based on the amount of switching activity produced inside the logic 
as a result of exercising that particular primary input. In practice, the WPRPG 
contains 10 to 50 times less test patterns than a deterministic test, which is 


useful in improving the fault coverage of defects. Furthermore, when used 
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with a fast fault simulator, it has been shown that WPRPG is a highly efficient 


form of test generation [Ref. 13]. 


B. SIGNALPROBABILITY 

The pseudorandom patterns generated by the LFSR can be weighted to 
alter the frequency of 1's to a fraction other than 0.5. The pseudorandom 
patterns developed by the LFSR are weighted by logically ANDing and ORing 
the output lines of the LFSR to change the frequency of occurrence of one's 
and zero's. An AND gate increases the probability of occurrences of zeros. 
The occurrence of one's is increase by the addition of an OR gate. Im 
achieving the occurrence of one's with probabilities other than 0.5, a network 
of AND and OR gates is employed at the outputs of the LFSR. The 
derivation of specific signal probabilities is achieved through two basic 


analytical probability formulas: 


P(An B) 2 P(A)P(B) 


f 


P(AU B) = P(A) + P(B) — P(A)P(B). 


We have observed that it is not always efficient or even possible to reach 
exact signal probabilities using the above formulas. However, in weighted 
test pattern generation, iterative use of these formulas leads to accepted signal 
probabilities. As an example, if the outputs of two LFSR stages are fed into an 
AND gate, the output will have a signal probability approaching 0.25. The 
underlying assumption is that the signal probability is 0.5 for any stage in an 
LFSR. The circuit in Fig. 4.1, shows the basic concepts [Ref. 11]. The weight, or 
signal probability generated by WPRPG can be controlled by the contents of 


23 


the control register. The AND gate whose output is labelled 2 has inputs 
from two stages of the LFSR. 1f bit number 3 of control register contains a 1, 
AND gate 2 will feed a 1 to the OR gate 25% of the time since 0.5 x 0.5 = 0.25. If 
bit number 3 becomes 0, AND gate 2 will be disabled and does not give any 
effect to the signal probability of output. The output of three AND gates, 
which contribute 0.5, 0.25, or 0.125, respectively, are under control of the 
value of control register. The XOR is driven by bit number 1 of the control 


register and serves as an inverter for the output of the OR gate. 





4 3 2 1 
Control Register 


Figure 4.1 Programmable Weighted Random Pattern Generator 
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C. TWO EXPERIMENTS 
1. WPRPG Netlist Simulation 

In order to generate WPRPG using Netlist, two programs are written: 
GLFSR and GWPRPG. The GLFSR generates an LFSR for the polynomial 
desired. The GWPRPG connects the additional circuit needed as mentioned 
in previous section into one netlist module called WPRPG.net. A set of 
experiments are repeated by using WPRPG.net. 

2. Circuit Layout 

The configuration of WPRPG shown in Fig. 4.1 consists of LFSR, 3 
AND gates, 1 OR gate, XOR gate and 4 bits control register. This circuit layout 
takes a silicon area of 462 x 1424 square units in scalable 34 CMOS. Similar to 
the unbiased LFSR discussed in Chapter III, this layout is extracted and 
simulated. The simulation results are validated by the netlist counterparts. 
For example, an LFSR of x16 4 x? + x9 +x? +1 has been clocked 700 cycles 
separately for initial values of 1011000000000000 and 1000000000000000. Table 
4.1 shows probabilities using different control register values when use 
1011000000000000 as initial value of the LFSR. For example, loading 1000 into 
the control register, we obtain the signal probability of 0.501429 which is 
greater than the theoretical 0.5. When we use 0100 as the control register 
value the signal probability is less than theoretical 0.25. The discrepancies 
here are due to the number of cycles we simulated. In order to obtain the 
accurate signal probability value, we have to increase the cycles of simulation 
fol. 

Table 4.2 shows the probabilities with initial LFSR value of 
1000000000000000. Comparing Table 4.1 and Table 4.2, we notice that different 
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initial values of LFSR may result in different signal probabilities. However, 
they both close to expected values. Therefore initial value of LFSR did not 
influence the probability in WPRPG. In other words, the output signal 
probabilities are controlled by the control register contents only. Finally, all of 
the experiment done above have been repeated using circuits created by the 
netlist generator. From the netlist generator, Table 4.3 shows the netlist 
simulation results that validates the WPRP circuit generated by the layout 
generator (Table 4.1). Similarly, Table 4.4 validates Table 4.2. As a conclusion, 
weighted pseudorandom pattern generation may generate less patterns than 
exhaustive test pattern generation at a price of extra silicon area for those 
AND, OR gates and control register. The usefulness of this biased test pattern 
generation depends on the tradeoffs between the pattern generation time and 


silicon area. 


TABLE 4.1 THE PROBABILITIES USING 1011000000000000 AS 
INITIAL VALUES OF LFSR (LAYOUT GENERATOR) 


Control Register | Simulated Probability | Expected Probability 


0.501429 
0.248571 


0.112557 
0.751429 
0.887143 
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TABLE 4.2 THE PROBABILITIES USING 1000000000000000 AS 
INITIAL VALUES OF LFSR (LAYOUT GENERATOR) 


Control Register 


1000 


Simulated Probability 


0.478571 
0.222857 
0.111429 
0.777143 
0.588571 









Expected Probability 


TABLE4.3 THE PROBABILITIES USING 1011000000000000 AS 
INITIAL VALUES OF LFSR (NETLIST GENERATOR) 


0.501429 | 
0.248571 


Control Register | Simulated Probability | Expected Probability 


0.112857 
0.751429 
0.887143 
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TABLE 4.4 THE PROBABILITIES USING 1000000000000000 AS 
INITIAL VALUES OF LFSR (NETLIST GENERATOR) 


Control Register | Simulated Probability | Expected Probability 


0.478571 0.5 
0.222857 
0.111429 
0.777143 
0.888571 









28 


V CONCLUSIONS 


This thesis has introduced an economical way of implementing the test 
pattern generation for built-in test: the internal form of LFSR. A layout 
generator as well as a netlist generator are written and validated. Similar 
generators have been written for weighted LFSR as well. The layout 
generator allows the user to produce mask specifications for test pattern 
generators that the circuit under test requires. In addition to validating the 
layout, one major contribution of the netlist generator is to explore various 
characteristics of a given generator polynomial. The generators written for 
this thesis have been used in another thesis work by Barus [Ref. 5]. Barus' 
work is developed concurrently with this thesis so there is a strong 
correlation between this thesis and Barus' work. With a basic understanding 
of these two theses work, one may gain an overall picture of the built-in test. 

The primitive polynomials have been studied by many researches, 
although nonprimitive ones are orphans in the research circle. In this thesis, 
an investigation into properties of nonprimitive polynomials has been 
performed using netlist generator described in Chapter III. The polynomials 
of degrees 3, 4 and 5 are summarized in Appendix C. There are some 
interesting properties or observations: 

1. the existence of inertial state that stay unchanged; 

2. the nonprimitive cycles are either disjoint or coincident; 

3. each primitive or nonprimitive cycle follows the sequence that every 


successor of a state i is 2i until the successor is greater than 2" - 1 and 
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then drops to a new state; the new state is dictated by the polynomial or 
feedback circuit. 
On the other hand, there are some conjectures that we leave here as open 
problems for further research: 
1. for a given nonprimitive polynomial p(x) how to find an initial state 
that gives the maximum nonprimitive cycle, 
2. for a given p(x), how to find an inertial state if any, 
3. what is the minimum change to the p(x) above such that we can 
modify it into a new primitive polynomial p(x), 
4. given a cycle or a finite set of test patterns, how to find a nonprimitive 
polynomials that generates the cycle. 
The last problem (4) above is important since we may want to have 
maximum fault coverage using only this nonexhaustive cycle when the 
circuit behavior does not require exhaustive patterns. Our current conjecture 


is that the solution might exist but may not be unique. 
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APPENDIXA: PROGRAM LISTINGS 


A. CRCNET 

/* 

PROGRAM NAME : CRCNET 

APPLICATION : To generate and simulate CRC for 
any polynomial 

*/ 


#include <stdio.h> 

#define fname_len 20 

#define len 200 

#define MAXDEG 100 

#define newline fprintf(fid, "\n") 


char initial [MAXDEG*2] ; 


main(argc, argv) 
int argc; 
char **argv; 


{ 

FILE *fid; 

char filebase[fname len], memory [40]; 
char fb[fname len]: 

char fc[fname len]: 

char fs[fname len]: 

char inp; 

int i, j, N-0, M, I-0, T; 
int xor[MAXDEG] ; 

int max[16]: 

int swi = 0; 


int cO = 1, ci = 1; 
int c2 = 1, c3 = 1; 
int c4 = 1, c5 = 1; 
int c6 = í, c7 = 2; 
int c8 = 1, c9 = Í; 
int k = í, m = Í; 


strcpy(filebase, argv[3]): 
strcpy(fb,filebase): 
strcpy(fs,filebase); 
strcpy(fc,filebase); 


if(argc !=4) 
{ 
printf("Usage: crcnet polynomial initial filenameln"); 
printf("Example : crcnet 111011 10101 fileln"); 
printf" for x s+x 4tx 3tx+1 ٦ 
exit(1); 


N = strlen(argv[1]) - 1; 
for(i=0; i<=N; i**) max[N-i] = argv[1][i] - 48; /* ascii O = 48 */ 


M = N; 


بم 
II‏ 


strlen(argv[1]);  /* I is the degree minus 1 */ 


512681222165131" s 
for(i=0; i< I; i++) 
{ 
if(argv[2][i]==49) /* ascii ’1’ has value 49 */ 
{ 
sprintf(memory,"h /d h /d ", 2xi, 2xi+1); 
strcat(initial, memory); 


) 
else { 


if (argv [2] [1]==48) 
( sprintf(memory,"l /d 1 Vd ", 2*i, 2*i+1); 
strcat(initial, memory); 


PE 
) /* end for */ 


em ee => => => => == ===> === ===> A‏ سے سے سے سے سے سے سے >= >= >= >= >= uA‏ سے س کے 


strcat(filebase,".net"): 
fid= fopen(filebase,"w"); 


fprontf(fid, (load ib. net On: 
fprintf(fid, “(load 6 6ٰ 
newline: 

fprintf CJ; hemline: 
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fprintf(fid, "node c1 555 
newline; newline; 
for(i=1; i<=N; i++) Í 

printed ۶109057۸01۳ 1), 

newline; 

) 
newline; 
for(i=1; i<=N; i++) í 

forint! (eid, ita s 105 


newline; 

} 
newline; 

fhprinti(fid input"); 
newline; 
newline; 


max[N] = max[0] = 1; 


/* to verify the polynomial */ 
printf(" \n\n\tX Ad + ",N); 
for (i = N-1; i>0; i--) 

{ 
if (max[i] == 1) 
printf("X^/d + ",i); 
} 
printr UNO"); 


for (i=N-1; i>0; i--) if(max[i] == 1) = k++; 


for(j=1; j<=k; j++) 
1 
prammer (fid 211157026217017 226 
newline; 


} 


newline; 
fprintf(fid, ") "); newline; newline; 


CoE: IN att tprintilfid, (MSIE ttftout/d ffinkd cl)1n”",1, 1); 
newline; 
for(i=1; i<=k; i++) 


{ 


fprimte rider 2 rorout/d'xorin.dl xorin/d2 JÁn“,i,1,1): 
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} 


newline; 


for (i=N-1; i>0; i--) 


{ 

if (max[i] == 1) 
{ 

fprintf(fid, "(connect ffin/d xorout/d)",N,c2); newline; 
Cath: 


fprintf(fid, "(connect xorinfd1 ffout/d)",es,N=1); newline: 
fprintf(fid, "(connect xorin/d2 ffout/d)",c8,M); newline; 
newline; 
newline; 
cott 
N--; 
} 
else if (max[i] == 0) 
{ 
fprintf(fid, "(connect ffin/d ffout/d)",N,N-1); newline; 
newline; 
Noa: 
} 
3 
fprintf(fid, "(connect ffin/d xorout/d)",N,c2); newline; 
fprintf(fid, "(connect xorin/di ffout/d)",c8,M); newline; 
fprintf(fid, "(connect xorin/d2 input)",c8); newline; 
fclose(fid); 


CREATE A FLATTENED NETLIST REPRESENTATION AND A BINARY CIRCUIT 
REPRESENTATION. 


e A > => => s A s ee =‏ سے که سے v.‏ سے سے سے سے s‏ سے سے سے سے سے سے سے سے سے سے سے سے سے سے سے سے سے سے سے سے سے s‏ “ سے سے سے سے سے سے سے سے سے سے سے o o o‏ سے = چ 


sprintf(memory,"netlist /s.net /s.sim -tcmos-pw",fb,fb); 
system(memory); 


sprintf(memory,'"presim /s.sim /s'",fb,fb); 
system(memory); 


-— => جع‎ === == === == == == == => FB (mm FF => =>» => A => => => => => => => => => => => aD جح‎ => => > => => => == == = = 


4 


Strcar (IC stim'); 
fid=fopen(fc,"w"); 


fprintf(fid, "time range O 100"); newline; 
forint (fid, "cl 2 10h. 1"); newline; 
fprintf(fid, "input 0 4s",initial); newline; 


fprintf(fid, "report 1 0"); newline; 

felose(fid): 

sprintf (memory, "gen time /s.stim #4s.time",fs,fs), 
system(memory); 


u a a a D WEB Cue ED ED D D ED D ED D ED D EB VER حعحت ست ست ست ست منت جسب‎ e a Gs a a Hn a a a e a s s s “m s s سے‎ s s s s “s s a جتت جت‎ “G s s. s ls GN up = up ہے سے‎ Po d m 


Sereat(fp,". 7"): 
fid=fopen(fb,"w"); 


fprintf(fid, "(load \"uwstd.1\")"); newline; 
tprintf(fid, "(load V'uvsim.1NV")"); nevwline; 
fprintf(fid, "(log-file \"⁄s.rlog\")",fs); newline; 
fprintf(fid, "(read-network \"%s\")",fs); newline; 
forint? (fid, "(sotq incr 100)"); newline: 

forinti (fid, "(sim-init)"): nevline: 

fprintf(fid, "(sim-init)"):; newline; 


Bprintf(fid, "(defvec (bit rem): 
for(i=M; i90: i--) 


{ 
Iprincf (fd, Vffout/d i); 
} 

fprintf (fid, JJ), 

newline; 


Eprintf(fid, "(def-report *(N" ب("‎ 
BEprintftfid, "input "): 

Eprinti(tid (ec rem)))"): newline: 
fprintf(fid, "(setq lanalyze t)"); newline; 
fprintf(fid, "(wr-format)"); newline; 
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fprinti(fid, “(load N (s.timea fs); newline; 
fprintf(fid, "exit"); newline; 

fclose(fid); 

sprintf(memory, "rnl %s.1",fs); 

system(memory); 

sprintf (memory, "print /s.rlog",fs); 
system(memory); 
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B. CRCMAG 


/* 

program name : crcmag; layout generator 
input : LFSR polynomial 

output : layout 

application : to generate crc layout 
*/ 


#include <stdio.h> 
#include "cfl.h" 


main() 
{ 

/*define the variables */ 
SYMBOL *80, *s1, *s2, *s3 ; 


int term_present[16], order=0, i; 


do 

{ 
printf("\n\tinput order: "); 
scanf("4d",%order) ; 


} 
while (order == 0); 
term present[order] = 1; 


term present [0]=1; 

for (i=order-1; i>0; i--) 
1 

printf("nitx"kd term - type '1' if present and ’0’ if not: ",i); 
scanf ("%d",£term present[i]), 
if (term present[i]!-1) 

term present[i]-0, 


) 


printf ("\n\n\tX°/d + ",order); 
for (i=order-1; i>0; i--) 
1 
if (term_present[i]==1) 
printf" X d +" i); 
) 
printf("iNn'"): 


erisete( format magic"); 
cflstart("scmos"); 


3f 


٤٣0۷4966706 MN), 


/* pieces of poly and poly with sizes */ 
s0=box("polysilicon",2,6); 

/* leaf cells (./mag location implied) */ 
si=gs("msff3"); 
s3=s2=gs("xor3") ; 
s3=bb(s2,s1); 


for (i=1; i<order; i++) 


1 
if (term present[i]--1) 
{ 
s3=bb(s3,s2): 
printf("\n\tTEST", i); 
} 
s3=bb(s3,s1); 
} 


s3=bbdx(s3,s0,-1); 
/* name the crcmag.mag */ 
ps("crcmag",s3); 


cflstop(); 
} 
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C. GLFSR 


/* 

program namn 'plfnr 

application : to generate and simulate lfsr for 
any polynomial 

*/ 


#include <stdio.h> 

#define fname_len 20 

#define len 200 

#define MAXDEG 100 

#define newline fprintf(fid, "\n") 


char initial [MAXDEG*2] ; 


main(argc, argv) 
int argc; 
char **argv; 


( 

FILE *fid; 

char filebase[fname len], memory[40]; 
char fb[fname len]; 

char fc[fname len]; 

char fs[fname len]; 

int i, j, N=0, M, I=0, T; 

int xor[MAXDEG]: 

int max[16]; 


int cO = 1, cl 1; 
meer? - 1, c3 = 1; 
int c4 = 1, c5 = i; 
int c6 = 1, c7 = 2; 
int c8 = 1, c9 = 1; 
int k = 0, m = 0: 
int p = 1, q = 0; 


strcpy(filebase, argv[3]); 
strcpy(fb,filebase); 
strcpy(fs,filebase); 
strcpy(fc,filebase); 


if(argc !=4) 
{ 
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printf("Usage: glfsr polynomial initial filenameln"); 

printf("Example : glfsr 111011 10101 file\n"); 

printf(" for x"5+x"4+x"3+x+1 with 10101\n"); 

6 

I 
N = strlen(argv[1]) - 1; 
for(i=0; i<=N; i++) max[N-i] = argvÅ1] [i] - 48, /* ascii 0 = 48 */ 
M = N; 


I = strlen(argv[1]); /* I is the degree minus 1 */ 


strcpy(initial," uS 
for(i=0; i<I; i++) 
1 
if (argv [2] [i]==49) /* ascii ’1’ has value 49 */ 
1 


sprintf(memory,"h Ad h Zd ", 2*i, 2*i+1); 
strcat(initial, memory); 
q =q+ 2*1*1; 
printf Cien i initial); 
J 
else 1 
if (argv [2] [i]==48) 
Sprintf(memory,"l Ad 1 %d ", 2*i, 2*i+1); 
strcat(initial, memory); 
q = q + 2*1*1; 
printf("/s\n", initial); 
A; 
} /* end for */ 


= > s s. ہت‎ mh mh D D CD CD CD CD CD CD CD CD CD نت‎ D AD D Gb ee ee aD D D D D 


ےب = D am‏ > حت D v.‏ ج جه ج ج ج D‏ جه D‏ جه ND‏ که جه جه جه جه جه جه جه جه جه جه جه جه = 


strcat(filebase,".net"): 
fid= fopen(filebase,"w"); 


fprintf(fid, "(load N"lib.netN")Nn"); 
fprintf(fid, "Cload ۶ً 1. 
newline: 

fprintf(fid, "("); newline; 

fprintf (fid, “noda cl O. 
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newline; newline; 
for(i-1; i«sN; i++) ( 
1111152210171 10741" 7 
newline; 
4 
newline; 
for(i=i; i<=N; i++) 4 
(porma. METIN AID, 


newline; 

} 
newline; 

fpeintf (fd, ” input”): 

newline; 
newline; 
max[N] = 1; 
max[0] = 1; 


/* to verify the polynomial */ 
printer AnXhNtA Ad +" N); 
for (i = N-1; i>0; i--) 

{ 

if (max{i] == 1) 
Print nc es 
} 

printr Clin”): 


for (i=N-1; i>0; i--) 
{ 
if (maxli| == 1) 
1 
krr: 
) 
else if (max[i] == O) 
1 
mss; 
) 
} 
for(j=1; j<=k; j++) 
{ 
15212510110 752000701215041 rorin/d2" j] J); 
newline; 


) 
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newline; 
fprintf(fid, ") "); newline; newline; 


for(i=l; i<=N: irt) fprintf(fid, “(msff fiout/dwirimy dee!) ۰۰ b 
newline; 


forl GER ریہ‎ 
{ 
fprintf (fid, i" (xor2 xorouthd 621174112 0 ODE 


} 


newline; 
/* 
INSERT NEW PROGRAM 
*/ 


for(i=1; i<=k-1; i**) 
1 
fprintf(fid, "(connect xorout%d xorin#d2)\n",i,i+1); newline; 
newline; 
m=i+1; 
) 
if(k==1) 
1 
m= 1 ; 
fprintf(fid, "(connect xorout/d ffin/d)\n'",m,p); newline; 
} 
else if(k>1) 
1 


fprintf(fid, "(connect xorout/d ffin/dDin",m,p); newline; 


+ 


for (i=1; i<=N-1; i++) 
{ 
if (max[i] == 1) 
{ 
fprintf(fid, "(connect ffoutMd xorin/di)",p,k); newline; 
fprintf (fid, "(connect ffouthd ffin/d)",p,p+1); nevline; 
newline; 
pus 
k--; 
} 
else if (max[i] == 0) 
1 
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fprintf(fid, "(connect ffout/d ffind)",p,p+1); newline; 
newline; 
ptt; 


J 
J 


fprintf(fid, "(connect ffout#d xorini2)",N); newline; 
fclose(fid); 


Le. کے پد کت دہ تہ کے ہے — سے سے سے کس کے کے کس نت‎ GE cum GEB GER GEM GEB Gum ED ED GER um دہ‎ m dem am cum dem s ccm ج‎ 


CREATE A FLATTENED NETLIST REPRESENTATION AND A BINARY CIRCUIT 
REPRESENTATION. 


do do => ===> s s === == == ===> سے‎ - - - - em 


sprintf(memory,"netlist %s.net %s.sim -tcmos-pw",fb,fb); 
system(memory); 

sprintf (memory, '"presim /s.sim %s'",fb,fb); 

system(memory); 


-—A amp o.” ”. .” سے ” ”””. کے کے سے کے‎ SB Se کے‎ => ===> > => cm D D ل‎ SF D do GS SB SF s SF s s s SF o do D o o |S GE 


= a aa ma ==» حست عت جست‎ ” ” Lu LLL LL سے >=== == == >= >= == === >= ل == مه‎ am am» ل‎ do do o س‎ 


strcat (fc, stinn"): 
fid=fopen(fc,"w"); 


fprintf(fid, "time range O 50"), newline, 

Bbranbpb(fid,; "cl 2 10 h 1"); newline; 

fprintf (fid, "ffouthd 1 4s x /d",N,initial,g/2); newline; 
fprintf(fid, "report 1 0"); newline; 


fclose(fid); 


sprintf (memory, "gen time %s.stim /s.time",fs,fs); 
system(memory); 


سب سب سے سے سے s GE»‏ سے کے کے سے سے کے کے D‏ کے حت ہت ہت ہت ہت ہت ہت ہت ہت ہت ہت ہت ہت ہت ہت ہت ہت ہت ہت ہت ہت ہت ہت سے سے سے سے سے am de de de‏ سے am‏ ہت ہت ہب ہت مت سے GE em am s‏ کے کے D > ew‏ 
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streat (ip, 1); 
fid=fopen(fb,"w"); 


fprintf(fid, "(load Wuwsta.1N NN, newline, 
fprintf(fid, "(load \"uwsim.1\")"); newline; 
fprincf(fid, "(log-file N"/s.rlogNU)U07 fs); naqlina, 
fprintf(fid, "(read-network \"%s\")",fs); newline; 
fprintf(fid, "(setq iner 100)") snewhine: 
fprinti(fid, “Csim-init)”); newline. 

fprintf(fid, "(sim-init)"); newline; 


fprintf(fid, "(defvec (bit rem"); 
for(i=1; i<=M; i++) 


1 
12212511107 "11020057 9% 
} 

5567356) ٦ 

newline; 


forintt (fid, (det reporta ELD 
fprontf(fid, "ffouepd i N); 


fprintf(fid, "(vec rem)))"); newline; 
fprintf(fid, "(setq lanalyze t)"); newline; 
fprintf(fid, "(wr-format)"); newline; 
fprintf(fid, "(load \'Y/s.time\")" fs): neulina; 
fprintf(fid, "exit"); newline; 

fclose(fid); 

sprintf (memory, "rnl /s.1",fs); 

system(memory); 

sprintf(memory, "print /s.rlog",fs); 
system(memory); 


} 
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D. GWPRPG 


program name : gwprpg 

application : 1. To connect LFSR and auxiliary circuit 
for generating different signal probability. 
Note that the LFSR should be of degree 16 or 
higher. | 

2. Having created the weighted LFSR, netlist, 

this program starts the execution of the 
netlist simulation. 


#include <stdio.h> 

#define fname len 20 

#define len 200 

#define MAXDEG 300 

#define newline fprintf(fid, "\n") 


main(argc, argv) 
int argc; 
char **argv; 


1 

FILE *fid; 

char filebase[fname len], memory[40]; 
char fb[fname len]; 

char fc[fname len]: 

char fs[fname len]; 

char fa[fname len]: 

char fm[fname len]: 

char f1[fname len]: 


char “ch, 

mer], d, g; 

int k=1, N=0, M, T,1=0; 
int xor[MAXDEG]; 

int max[16]; 


printf("\n\tEnter file name for lfsr C 
Scanf("Vs" fl); 


printf("\n\tEnter file name for nand p 
scanf("/s",fa): 
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printf("\n\tEnter file name for prpg E 
scanf("%s",filebase) ; 
strcpy(fb,filebase); 
strcpy(fs,filebase); 
strcpy(fc,filebase); 


/* create file .stim and generate file .time */ 


/*= -—-——-——-—------ 7 * / 


streatife ".stim!): 
fid=fopen(fc,"w"); 


fprintf(fid, "time range O 1000"); newline; 


fprintf(fid, "cl 2h O 1L 1"); newline; 
fprintf (fid, "input O h O h 11 21 3 h4 h 5 1 6 ور(‎ 
newline; 
printf("\n\tEnter number of bits number 4 OS 
scanf("/d",gi); 
if(i==1) 
{ 
fprintf(fid, "i 2 h O h 1"); newline; 
} 
else 
{ 
fprintf (fid, "i 2 1 O 1 1"); newline; 
} 


printf("\n\tEnter number of bits number 3 NE 
scanf("/d",gg); 
if(g==1) 
{ 
fprintf(fid, "g 2 h O h 1"); newline; 
} 
else 
1 
fprintf(fid, "g 2 1 0 1 1"); newline; 
} 


printf("\n\tEnter number of bits number 2 اد‎ 
scanf("/d",&d); 
if(d==1) 

1 
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fprintf(fid, "d 2h O h 1"); newline; 


} 


else 


{ 


fprintt(fid, "2271073 1”), newline; 


} 


printf("\n\tEnter number of bits number 1 DE 
Scanf('Jd'.235; 


if(j==1) 
{ 


fprintf(fid, "j 2h Oh 1"); newline; 


} 


else 


1 


fprints Pid; ') 2 10.1.1"); newline; 


NG 


fprintf(fid, "report 1 O"), newline, 


fclose(fid); 


sprintf(memory, "gen time /s.stim %s.time",fs,fs); 
system(memory); 


/* create file .net, netlist and presim */ 


[* ------------------------------------ */ 


strcat(filebase,".net"); 
fid= fopen(filebase,"w"); 


fprintf(fid, 
fprintf(fid, 
tprantt(fid, 
5۶07176 0) ر9‎ 
newline; 

iprintf(fid, 


"(load \"lib.net\")\n"); 

(load Ms. .netv Jia" fl): 
"(load Vs. netN')Nn' fa); 
"(load \"xor2.net\”")\n®); 


"(node i j d g)"); newline; 


fprintf(fid, "(connect 
fprintf(fid, "(connect 
fprintf(fid, "(connect 
fprintf(fid, "(connect 


fprintf(fid, "(connect 
fprincef fideo (connect 
fprintf(fid "(Connect 


ffoutii nandin411)"); newline; 
ffout12 nandin412)"); newline; 
ffout13 nandin421)"); newline; 
nandin422 d)"); newline; 


ffout14 nandin311)"); newline; 


ffouti5 nandin312)"); newline; 
nandin322 g)"); newline; 
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fprintf(fid, "(connect ffout16 nandin211)"); newline; 
fprintf(fid, "(connect nandin212 1)"), newline; 
fprintf(fid, "(connect xorin212 j)"); newline; 


fclose(fid); 

sprintf(memory, 'netlist %s.net %s.sim -tcmos-pw",fb,fb) ; 
system(memory) ; 

sprintf (memory, 'presim /s.sim /s',fb,fb); 

system(memory); 


/* create file .1 and simulate */ 


/[* --------------------------- * / 


streat(rp Jar) 
fid=fopen(fb,"w"); 


fprintf(fid, "(load \"uwstd.1\")"); newline; 
fprintf(fid, "(load \"uwsim.1\")"); newline; 
fprintf (fid, "(log-file \"⁄s.rlog\")",fs); newline; 
fprintf(fid, "(read-network \"%s\")",fs); newline; 
fprintf(fid, "(setq incr 100)"); newline; 
fprintf(fid, "(sim-init)"); newline; 

fprintf(fid, "(sim-init)"); newline; 


fprintf(fid, "(defvec ”(bit rem "); 
for(i=1; i<=N; i++) 


{ 

fprintf(fid, “ffold a, 

|; 

fprinti(fid, 15); 
newline; 


fprintf (fid FY (dof-roport NR), 
fprintf(fid, "i g d j xorout21'); 

fprintf(fid, "(vec rem)))"); newline; 
fprintf(fid, "(setq lanalyze t)"); newline; 
fprintf(fid, "(wr-format)"); newline; 
fprintf(fid, "(load Aa time fa) newline; 
fprintf(fid, "exit"); newline; 

fclose(fid); 

sprintf(memory, "rnl %s.1",fs); 

system(memory); 


/ x 


sprintf(memory, "print %s.rlog",fs); 
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system(memory); 


* / 
/* COUNT THE PROBABILITY */ 
sprintf (memory, "count %s.rlog'",fs); 


system (memory) ; 


} 
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APPENDIX B: 


The listing below shows one sample execution of netlist generator *crcnet? 
on polynomial x°5 + x°4 + x°3 + x + 1 (111011), with initial value ٣ 
and filename x54310. 


Y crcnet 111011 10101 x54310 
X^5 + X74 + X7"3 + X"1 + 1 


Version 4.2 
presim: can not open config file cmos-pw.typ.config, 
alternatively using /tools/nwlis/lib/technology/cmos-pw.typ.config 
116 nodes; transistors: enh=80 intrinsic=0 p-chan=80 dep=0 low-power=0 
Pullup=0 resistor=0 
Total transistors eliminated = 128 
Version 4.2 
Loading uwsim.l 
Done loading uwsim.1 
; 76 nodes, transistors: enh=16 intrinsic=0 p-chan=16 dep=0 low-power=0 
Pullup=0 resistor=0 


; Report format of logic analyzer style output 
time cl input rem 


10 0 1 00000 
20 1 1 00000 
30 0 0 1 
40 1 0 00001 
50 0 1 00010 
60 1 1 00010 
70 0 0 00101 
80 1 0 00101 
90 O 1 0 
100 1 1 01010 
110 0 0 10101 
120 1 0 10101 
130 0 0 10001 
140 1 O 10001 
150 00 11001 
160 1 0 11001 
170 00 01001 
180 1 0 01001 
190 0 0 10010 
200 1 0 10010 
219: O OSTIT 
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220 
230 
240 
250 
260 
270 
280 
290 
300 
310 
320 
330 
340 
350 
360 
310 
380 
390 
400 
410 
420 
430 
440 
450 
460 
470 
480 
490 
500 
510 
520 
530 
540 
550 
560 
570 
580 
590 
600 
610 
620 
630 
640 
650 
660 


== O = نی عر و بر 9ٍ عر رو بپےم نی بےم 9ٗ ہرم وہ‎ HO HO HO HO KHO HO KHO HO HO KHO HO kh O حرم‎ O KHO m 
O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O OO O O O O O O O O 


111 
00101 
00101 
01010 
01010 
10100 
10100 
10011 
10011 
11101 
11101 
00001 
00001 
00010 
00010 
00100 
00100 
01000 
01000 
10000 
10000 
11011 
11011 
01101 
01101 
11010 
11010 
01111 
01111 
11210 
51110 
00111 
00111 
01110 
01110 
11100 
11100 
00011 
00011 
00110 
00110 
01100 
01100 
11000 
11000 
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670 
680 
690 
700 
710 
720 
730 
740 
750 
760 
TTO 
780 
T90 
800 
810 
820 
830 
840 
850 
860 
870 
880 
890 
900 
910 
920 
930 
940 
950 
960 
970 
980 
990 
1000 


OD HO HO HO KHO HO HO KH O HO KH O KH O نم ںی نم‎ KH O a O an Or O 


ONG OCO O O 0 OTO 0 O 0 6 GO نی‎ OO OG O OC O OVO O COESO © 
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001 
10110 
10110 
10111 
10111 
10101 
10101 
10001 
10001 
11001 
11001 
01001 
01001 
10010 
10010 
2111] 
11111 
00101 
00101 
01010 
01010 
10100 
10100 
10011 
10011 
11101 
11101 
00001 
00001 
00010 
00010 
00100 


1 0 00100 
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APPENDIX C: COMPARISON NONPRIMITIVE AND 
PRIMITIVE SEQUENCE 





Nonprimitive (3,0) 
Initial Value Periodic Sequence 


22.65 















o IN 


Initial Value Periodic Sequence 
Tend; ۶5۵ 
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| 








15 15 
| 
, 
| 
13 13 

Nonprimitive (4,3,1,0) 


++ [sms nn 
| 
کک‎ 
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Nonprimitive (4,3,2,0) 


Initial Value Periodic Sequence 


1 
: 
: 
Primitive (4,1,0) 
3 
Primitive (4,3,0) 
1, 2, 4, 8, 9, 11, 15, 7, 14, 5, 10, 13, 3, 6, 12 


1 
3 
11 
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Nonprimitive (5,0) 






Initial Value Periodic Sequence 


1,2,4,8,16,3,6,12,24,19,5,10,20,11,22,15,30,31,29,25,17 
EE NE EA 


142623 


1 
3 
7 
11 
15 
31 


1 
7 
11 
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Nonprimitive (5, 4, 3, 0) 





Initial Value Periodic Sequence 


120810 5, 11,22.21,19, 51, 4,14 28 








4100612 9 
5,۰10,120: 1177-27 0 


13, 6 


Nonpnmitive (5,3,2,0) 


Initial Value Periodic Sequence 
1 1, 2,4,8,16, 13, 26, 25, 31, 19, 11, 22 


1 

3 
13 
23 


3⁄6 12. 24229, `23 

99.0 

7, 14, 28, 21 
7 






15 153017 
27 2 


Nonprimitive (5, 2, 1, 0) 


Initial Value Periodic Sequence 
1, 2, 4, 8, 16, 7, 14, 28, 31, 25, 21, 13, 26, 19 


9 


2 


1 
3 
5 
11 
29 
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Nonprimitive (5,4,2,0) 
Initial Value Periodic Sequence 
1,2,4,8,16,21,31,11,22,25,7,14,28,13,26 


361222510/2029 15,09 18102327 


Nonprimitive (5,4,3,2,1,0) 


Initial Value Periodic Sequence 


1:2 1 
لك 12 62 رق‎ 195 O 
5, 10, 207 2 As 


9, 18, 27 
11, o RR وو‎ 19, 25, 13026 
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Nonprimitive (5, 3, 1, 0) 


Initial Value Periodic Sequence 


1,2,4,8,16,11,22,7,14,28,19,13,26,31,21 
3,6,12,24,27,29,17,9,18,15,30,23,5,10,20 


NI 
cn 


N 


Nonprimitive (5, 4, 1, 0) 
Initial Value Periodic Sequence 

L 2 4 6 16 19 21, 25 
902012, 224 

5, 10, 20, 27 

7 6 
9۲۷18 29 


15, 30 


حم 
1 


= 
ng 


حم 
^ 


Nonprimitive (5, 4, 2, 0) 


Initia] Value Periodic Sequence 


1,2,4,8,16,21,31,11,22,25,7,14,28,13,26 
3,0,12,24,5,10,20,29,15,30,9,18,17,23,27 


حم 
O‏ 


حم 
O‏ 


Nonprimitive (5, 4, 3, 2, 1, 0) 

Initial Value Periodic Sequence 
12٦ 
ود‎ 241530 
K 020, 23 17602 
7, 14, 28, 

9, 18, 27 

11; 22: 19 25; 13; 26 


== 
= 
— 


QN 
NO 


NI 
خم‎ 





















Primitive 


(5, 3, 0) | | 


In'''sl Value Periodic Sequence 


1, 2, 4,8, 16, 9, 18, 13, 26, 29, 19, 15, 30, 21, 3, 6, 12, 24, 
25, 2?,31, 23, 7, 14, 28, 17, 11; 22 5 10, 20 
Primitive (5,2,0) | i 


Initial Value Periodic Sequence 


1,2, 4, 8, 16, 5, 10, 20, 13, 26, 17, 7, 14, 28, 29, 31, 27, 19, 
1 


3, 6, 12, 24, 21, 15, 30, 25, 23, 11, 22, 9, 18 
Pnmitive (5,4,3,2,0) 


1, 2, 4, 8, 16, 29, 7, 14, 28, 5, 10, 20,21, 23, 19, 27, 11, 22, 
17, 31, 3, 6, 12, 24, 13, 26, 9, 18, 25, 15, 30 


1, 2, 4, 8, 16, 15, 30, 19, 9, 18, 11, 22, 3, 6, 12, 24, 31, 17, 
13, 26, 27, 25, 29, 21, 5, 10, 20, 7, 14, 28, 23 


Primitive (5,4,2,1,0) 
Initial Value Periodic Sequence 


1, 2, 4, 8, 16, 23, 25, 5, 10, 20, 31, 9, 18, 19, 17, 21, 29, 13, 
1 26, 3, 6, 12, 24, 7, 14, 28, 15, 30, 11, 22, 27, 


Primitive (5,4, 3,1,0) 
Initial Value Periodic Sequence 


1, 2, 4, 8, 16, 27, 13, 26, 15, 30, 7, 14, 28, 3, 6, 12, 24, 11, 
1 22, 23, 21, 17, 25, 9, 18, 31, 5, 10, 20, 19, 29 
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` ky lp, la, hte ee Pl ENA KR A LR GR VER UR AAA. TS ew ہم‎ oe wr ١ 
> lg DAR A U de enn ا‎ ing NR L Se pA nei Me pin ati P I 
NS ge pr ee وچ‎ SAGAS) TX 0. ہم سی نے ادن یسا ایی ہیں سح یت‎ A + 
à NG ا تنا‎ Å n پا‎ Q ١ AAA Á a Sty AAA AA A mp S É) nn, 5 
WS eu Q^ RA D pn er ipd RE ولواب‎ a Ach, c e rae i a e gn PETTY TUKOY ۾ کي‎ dr Å لوجاک اتا‎ " ñ 
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